Database Tutorials Automated Backup এবং Recovery Techniques গাইড ও নোট

413

Automated Backup এবং Recovery Techniques PostgreSQL ডেটাবেসের জন্য অত্যন্ত গুরুত্বপূর্ণ, কারণ এটি ডেটার সুরক্ষা, ব্যাকআপ নিশ্চিতকরণ এবং দ্রুত পুনরুদ্ধার নিশ্চিত করে। PostgreSQL-এ কিছু উন্নত ব্যাকআপ ও রিকভারি পদ্ধতি রয়েছে, যেগুলি ডেটাবেস অ্যাডমিনিস্ট্রেটরদের জন্য সুবিধাজনক। এখানে Automated Backup এবং Recovery Techniques নিয়ে বিস্তারিত আলোচনা করা হবে।


1. Automated Backup in PostgreSQL

Automated Backup হল একটি প্রক্রিয়া যেখানে ব্যাকআপের কাজ স্বয়ংক্রিয়ভাবে করা হয় নির্দিষ্ট সময়সীমার মধ্যে। PostgreSQL-এ বেশ কিছু পদ্ধতি আছে যেগুলির মাধ্যমে আপনি ব্যাকআপ স্বয়ংক্রিয়ভাবে পরিচালনা করতে পারেন।

a. pg_dump and pg_restore for Backup and Restore

pg_dump হল PostgreSQL-এর সবচেয়ে সাধারণ ব্যাকআপ টুল যা ডেটাবেসের সম্পূর্ণ কপি তৈরি করে। আপনি এটি একে একে কন্ট্রোল করে ব্যাকআপের সময় এবং ফ্রিকোয়েন্সি নির্ধারণ করতে পারেন।

pg_dump-এর মাধ্যমে ব্যাকআপ নেওয়া:

pg_dump -U username -h localhost -F c -b -v -f /path/to/backup/my_database.backup my_database

এখানে:

  • -F c: কাস্টম ফরম্যাটে ব্যাকআপ
  • -b: বড় অবজেক্টগুলিও ব্যাকআপে অন্তর্ভুক্ত করা
  • -v: বর্ননামূলক (verbose) আউটপুট
  • -f: ব্যাকআপ ফাইলের নাম এবং লোকেশন

pg_restore দিয়ে ব্যাকআপ পুনরুদ্ধার:

pg_restore -U username -h localhost -d my_database -v /path/to/backup/my_database.backup

b. Automating pg_dump with cron (Linux/Unix)

যেহেতু আপনি PostgreSQL-এ রেগুলার ব্যাকআপ স্বয়ংক্রিয়ভাবে চালাতে চান, আপনি cron jobs ব্যবহার করতে পারেন (Linux বা Unix সিস্টেমে)। এটি নির্দিষ্ট সময়ে ব্যাকআপ ফাইল তৈরির জন্য ব্যবহার করা হয়।

Cron job সেটআপ:

  1. crontab -e কমান্ড দিয়ে crontab ফাইল এডিট করুন।
  2. নিচের মতো একটি cron job যোগ করুন:

    0 2 * * * /usr/bin/pg_dump -U username -h localhost -F c -b -v -f /path/to/backup/my_database_$(date +\%Y\%m\%d).backup my_database
    

এটি প্রতিদিন রাত ২টায় ব্যাকআপ নেবে এবং ব্যাকআপ ফাইলের নামের সাথে বর্তমান তারিখ যুক্ত করবে।

c. Continuous Archiving and Point-in-Time Recovery (PITR)

PITR হল একটি অত্যন্ত শক্তিশালী ব্যাকআপ পদ্ধতি যা আপনাকে ডেটাবেসের নির্দিষ্ট একটি সময়ের অবস্থায় ফিরে যেতে সাহায্য করে। PostgreSQL এ এটি WAL (Write-Ahead Logging) ফিচার ব্যবহার করে।

  1. Archiving WAL files:
    • PostgreSQL-এ WAL archiving চালু করতে হলে archive_mode এবং archive_command কনফিগার করতে হয়।
archive_mode = on
archive_command = 'cp %p /path/to/archive/%f'

এটি সমস্ত WAL ফাইলকে আর্কাইভে সংরক্ষণ করবে। এই ফাইলগুলো আপনাকে পরে PITR-এর মাধ্যমে পুনরুদ্ধার করতে সহায়তা করবে।

  1. Restore with PITR:
    • PITR ব্যাকআপ পুনরুদ্ধার করতে base backup এবং WAL logs ব্যবহার করতে হয়।
# Step 1: Restore the base backup
pg_restore -U username -h localhost -d my_database /path/to/backup/base_backup

# Step 2: Apply WAL logs to restore the database to a specific point in time
cp /path/to/archive/wal/* /path/to/pg_wal/
  1. Recovery Target Time:
    • আপনি recovery_target_time প্যারামিটার ব্যবহার করে নির্দিষ্ট একটি সময়ের পরে ডেটাবেস পুনরুদ্ধার করতে পারেন।
recovery_target_time = '2024-11-25 03:00:00'

2. Recovery Techniques in PostgreSQL

Recovery Techniques হল ডেটাবেসের পুনরুদ্ধার প্রক্রিয়া, যেখানে pg_restore, WAL, এবং Point-in-Time Recovery (PITR) এর মাধ্যমে ব্যাকআপ থেকে ডেটা ফিরে আনা হয়।

a. Restoring from pg_dump Backup

আপনি যদি pg_dump দিয়ে ব্যাকআপ নিয়ে থাকেন, তবে pg_restore বা psql কমান্ড দিয়ে ডেটাবেস পুনরুদ্ধার করতে পারেন।

  1. Using pg_restore:
pg_restore -U username -h localhost -d my_database -v /path/to/backup/my_database.backup
  1. Using psql (SQL dump):
psql -U username -h localhost -d my_database -f /path/to/backup/my_database.sql

b. Restoring from WAL Logs

PostgreSQL WAL logs-এর মাধ্যমে আপনাকে ডেটাবেসকে একটি নির্দিষ্ট সময়ে পুনরুদ্ধার করতে সহায়তা করে।

  1. Restore Base Backup:
    • আপনি যখন base backup তৈরি করেন, তখন শুধুমাত্র WAL ফাইলগুলির মাধ্যমে ডেটাবেস পুনরুদ্ধার করতে হবে।
  2. Replaying WAL Files:
    • WAL ফাইলগুলো পুনরুদ্ধার করতে, আপনার উচিত আর্কাইভ ফোল্ডারে সংরক্ষিত ফাইলগুলো পুনঃপ্রয়োগ করা:
# Copy WAL files back to the pg_wal directory
cp /path/to/archive/wal/* /path/to/pg_wal/

# Restart PostgreSQL
pg_ctl restart -D /path/to/data/directory
  1. Using recovery.conf File:
    • PITR চালু করার জন্য, আপনি একটি recovery.conf ফাইল ব্যবহার করতে পারেন যেখানে restore_command এবং recovery_target_time কনফিগার করতে হয়।
restore_command = 'cp /path/to/archive/%f %p'
recovery_target_time = '2024-11-25 03:00:00'

c. Restore to a Different Server

Backup & Recovery এর সময় অনেক ক্ষেত্রে আপনাকে ব্যাকআপ ডেটা অন্য একটি সার্ভারে পুনরুদ্ধার করতে হতে পারে। এই অবস্থায়, ব্যাকআপ ফাইলটি অন্য সার্ভারে pg_restore বা psql এর মাধ্যমে পুনরুদ্ধার করা হয়।

# On the target server:
pg_restore -U username -h new_host -d new_database /path/to/backup/my_database.backup

3. Best Practices for Backup and Recovery

  1. Automate Backups:
    • ব্যাকআপ স্বয়ংক্রিয় করতে cron job বা PostgreSQL-র native pg_basebackup এবং pg_dump ব্যবহার করুন।
  2. Use pgBackRest or Barman for Advanced Backup Solutions:
    • যদি আপনি আরও উন্নত ব্যাকআপ এবং রিকভারি কৌশল চান, তবে PostgreSQL-এ pgBackRest বা Barman এর মতো টুলস ব্যবহার করতে পারেন।
  3. Test Backups Regularly:
    • ব্যাকআপগুলো পুনরুদ্ধার করার জন্য নিয়মিত পরীক্ষা করুন। শুধুমাত্র ব্যাকআপ তৈরি করা নয়, পুনরুদ্ধার প্রক্রিয়াটি নিশ্চিত করতে হবে।
  4. Monitor Backup Process:
    • ব্যাকআপ প্রক্রিয়া মনিটর করতে Postgres-এ লগ ফাইল ব্যবহার করুন এবং ব্যাকআপ সময় ফাইলগুলোর অবস্থান নিশ্চিত করুন।
  5. Consider Compression:
    • ব্যাকআপ ফাইলের সাইজ ছোট করতে compression ব্যবহার করুন, বিশেষত যদি বড় ডেটাবেস থাকে।

সারাংশ

PostgreSQL-এ Automated Backup এবং Recovery Techniques ব্যবহার করা অত্যন্ত গুরুত্বপূর্ণ ডেটা সুরক্ষা এবং প্রাপ্যতা নিশ্চিত করতে। pg_dump, pg_restore, এবং PITR (Point-in-Time Recovery) পদ্ধতিগুলির মাধ্যমে সহজেই ব্যাকআপ তৈরি এবং পুনরুদ্ধার করা সম্ভব। ট্রিগার সময় নির্ধারণ, সংরক্ষিত WAL ফাইলের ব্যবহার এবং recovery.conf কনফিগারেশন ফাইলের মাধ্যমে পুনরুদ্ধার করা যেতে পারে।

Content added By
Promotion

Are you sure to start over?

Loading...